DataGridView是C#中在处理显示表格数据时常用的控件,但是在使用过程中,会发现复制DataGridView控件中的内容比较容易,而把剪切板中拷贝的内容黏贴到DataGridView控件中比较复杂,下面用一种简单的方式实现复制功能:
代码如下: DataGridView的KeyDown事件+黏贴数据方法
///
/// DataGridView的KeyDown事件
///
///
///
private void dgv_KeyDown(object sender, KeyEventArgs e)
{
//判断是否按下:Ctrl+V
if (Control.ModifierKeys == Keys.Control && e.KeyCode == Keys.V)
{
//对象不为null,且对象为DataGridView类型
if (sender != null && sender.GetType() == typeof(DataGridView))
DataGirdViewCellPaste((DataGridView)sender);//调用黏贴方法
}
}
///
/// 向DataGridView控件粘贴数据
///
public void DataGirdViewCellPaste(DataGridView dgv)
{
if (dgv.CurrentCell == null)//判断当前单元格已选中,复制黏贴单元格初始位置
return;
int insertRowIndex = dgv.CurrentCell.RowIndex;//获取当前单元格行索引,打印单元格内容调用
int insertColIndex = dgv.CurrentCell.ColumnIndex;//获取当前单元格列索引,打印单元格内容调用
string pasteText = Clipboard.GetText();//获取当前剪切板的内容(黏贴内容必须是表格形式)
if (string.IsNullOrEmpty(pasteText))//剪贴板内容不为空
return;
#region 获取剪贴板内容的行、列数
//剪切板内容:21\t\t\r\n11\t12\r\n(\t:表示空格;\r\n:表示换行)
#region 获取行数
char[] c = pasteText.ToCharArray();//化整为零,将字符串转化成字符数组,逐个遍历
int RowCount = 0;//行数初始为零
for (int i = 0; i
RowCount++;
}
}
//判断复制范围是否在最大行范围内:(黏贴内容行数-1)+(当前单元格行索引值+1) > 表格总行数
//(黏贴内容行数 -1):因为有一行刚好黏贴在当前行
if (RowCount + insertRowIndex > dgv.RowCount)
{
MessageBox.Show("粘贴的行数不正确");
return;
}
#endregion
#region 获取列数
string[] s = pasteText.Split(new char[] { '\r', '\n' });//根据'/r'、'/n',把数据分为行单位内容
string[] Col = s[0].Split('\t');//根据'\t',获取每行单元格数,也就是列数
int ColCount = Col.Length;//列数
//判断复制范围是否在最列行范围内:(黏贴内容列数-1)+(当前单元格列索引值+1) > 表格总列数
if (ColCount + insertColIndex > dgv.ColumnCount)
{
MessageBox.Show("粘贴的列数不正确");
return;
}
#endregion
#endregion
#region 黏贴单元格内容
List listRow = new List();//声明集合,存储行单位内容
for (int i = 0; i
listRow.Add(s[i]);
}
}
//黏贴单元格内容到表格上
for (int iR = 0; iR
//注意黏贴单元格索引位置:在当前单元格的初始索引上叠加
dgv[iC + insertColIndex, iR + insertRowIndex].Value = listRow[iR].Split('\t')[iC];
// listRow[iR]:第[iR+1]行单元格内容
// listRow[iR].Split('\t'):把第[iR+1]行单元格内容划分
// listRow[iR].Split('\t')[iC]:提取第[iR+1]行的第[iC+1]个单元格内容
}
}
#endregion
}
*注意:此方法目前只测试了,从Excel或是Word的表格向DataGridView控件粘贴内容
|